home *** CD-ROM | disk | FTP | other *** search
/ CU Amiga Super CD-ROM 16 / CU Amiga Magazine's Super CD-ROM 16 (1997-10-16)(EMAP Images)(GB)[!][issue 1997-11].iso / CUCD / Graphics / Ghostscript / source / store.h < prev    next >
C/C++ Source or Header  |  1995-02-07  |  9KB  |  237 lines

  1. /* Copyright (C) 1989, 1995 Aladdin Enterprises.  All rights reserved.
  2.   
  3.   This file is part of Aladdin Ghostscript.
  4.   
  5.   Aladdin Ghostscript is distributed with NO WARRANTY OF ANY KIND.  No author
  6.   or distributor accepts any responsibility for the consequences of using it,
  7.   or for whether it serves any particular purpose or works at all, unless he
  8.   or she says so in writing.  Refer to the Aladdin Ghostscript Free Public
  9.   License (the "License") for full details.
  10.   
  11.   Every copy of Aladdin Ghostscript must include a copy of the License,
  12.   normally in a plain ASCII text file named PUBLIC.  The License grants you
  13.   the right to copy, modify and redistribute Aladdin Ghostscript, but only
  14.   under certain conditions described in the License.  Among other things, the
  15.   License requires that the copyright notice and this notice be preserved on
  16.   all copies.
  17. */
  18.  
  19. /* store.h */
  20. /* Assignment-related macros */
  21. #include "ialloc.h"            /* for imemory masks & checks */
  22.  
  23. /*
  24.  * Macros for storing a ref.  We use macros for storing into objects,
  25.  * since the storage manager needs to be able to track stores for
  26.  * save/restore and also for global/local checking.
  27.  * We also use macros for other ref assignments, because (as it happens)
  28.  * Turbo C generates pretty awful code for doing this.
  29.  *
  30.  * There are three cases that we need to distinguish:
  31.  *    - Storing to a stack (no special action);
  32.  *    - Storing into a newly created object (set l_new);
  33.  *    - Storing into a slot of an existing object (check l_new in
  34.  *        old value, set in new value).
  35.  * The macros are called
  36.  *    <make/store><new_type><case>(place_to_store, new_value)
  37.  * where <case> is nothing for storing to the stack, _new for storing into
  38.  * a new object, and _old for storing into an existing object.
  39.  * (The _old macros also take a client name for tracing and debugging.)
  40.  * <new_type> and new_value are chosen from the following alternatives:
  41.  *    ref_assign    POINTER TO arbitrary ref
  42.  *    make_t        type (only for null and mark)
  43.  *    make_tv        type, value field name, value
  44.  *              (only for scalars, which don't have attributes)
  45.  *    make_tav    type, attributes, value field name, value
  46.  *    make_tasv    type, attributes, size, value field name, value
  47.  * There are also specialized make_ macros for specific types:
  48.  *    make_array, make_int, make_real, make_bool, make_false, make_true,
  49.  *    make_mark, make_null, make_oper, make_[const_]string, make_struct.
  50.  * Not all of the specialized make_ macros have _new and _old variants.
  51.  *
  52.  * For _tav and _tasv, we must store the value first, because sometimes
  53.  * it depends on the contents of the place being stored into.
  54.  *
  55.  * Note that for composite objects (dictionary, file, array, string, device,
  56.  * struct), we must set a_foreign if the contents are allocated statically
  57.  * (e.g., for constant C strings) or not by the Ghostscript allocator
  58.  * (e.g., with malloc).
  59.  */
  60.  
  61. /*
  62.  * Define the most efficient ref assignment macro for the platform.
  63.  */
  64. /*
  65.  * Assigning the components individually is fastest on Turbo C,
  66.  * and on Watcom C when one or both of the addresses are
  67.  * already known or in a register.
  68.  */
  69. #define ref_assign_inline(pto,pfrom)\
  70.     ((pto)->value = (pfrom)->value,\
  71.      (pto)->tas = (pfrom)->tas)
  72. #ifdef __TURBOC__
  73.     /*
  74.      * Move the data in two 32-bit chunks, because
  75.      * otherwise the compiler calls SCOPY@.
  76.      * The cast to void is to discourage the compiler from
  77.      * wanting to deliver the value of the expression.
  78.      */
  79. #  define ref_assign(pto,pfrom)\
  80.     discard(ref_assign_inline(pto, pfrom))
  81. #else
  82.     /*
  83.      * Trust the compiler and hope for the best.
  84.      * The MIPS compiler doesn't like the cast to void.
  85.      */
  86. #  define ref_assign(pto,pfrom)\
  87.     (*(pto) = *(pfrom))
  88. #endif
  89.  
  90. /****** NOTE: the following declarations are duplicated from isave.h. ******/
  91.  
  92. int alloc_save_change(P4(gs_dual_memory_t *, const ref *pcont,
  93.              ref_packed *ptr, client_name_t cname));
  94. int alloc_save_level(P1(const gs_dual_memory_t *));
  95.  
  96. /****** END duplicated declarations. ******/
  97.  
  98. #define ialloc_save_change(pcont, ptr, cname)\
  99.   alloc_save_change(idmemory, pcont, ptr, cname)
  100. #define ialloc_is_in_save() (idmemory->save_level > 0)
  101. #define ialloc_test_mask (idmemory->test_mask)
  102. #define ialloc_new_mask (idmemory->new_mask)
  103. #define ref_must_save(pto)\
  104.   ((r_type_attrs(pto) & ialloc_test_mask) == 0)
  105. #define ref_do_save(pcont, pto, cname)\
  106.   ialloc_save_change(pcont, (ref_packed *)(pto), cname)
  107. #define ref_save(pcont, pto, cname)\
  108.   discard((ref_must_save(pto) ? ref_do_save(pcont, pto, cname) : 0))
  109. #define ref_mark_new(pto) ((pto)->tas.type_attrs |= ialloc_new_mask)
  110. #define ref_assign_new(pto,pfrom)\
  111.   discard((ref_assign(pto,pfrom), ref_mark_new(pto)))
  112. #define ref_assign_new_inline(pto,pfrom)\
  113.   discard((ref_assign_inline(pto,pfrom), ref_mark_new(pto)))
  114. #define ref_assign_old(pcont,pto,pfrom,cname)\
  115.   (ref_save(pcont,pto,cname), ref_assign_new(pto,pfrom))
  116. #define ref_assign_old_inline(pcont,pto,pfrom,cname)\
  117.   (ref_save(pcont,pto,cname), ref_assign_new_inline(pto,pfrom))
  118. /* ref_mark_old is only needed in very unusual situations, namely, */
  119. /* when we want to do a ref_save just before a save instead of */
  120. /* when the actual assignment occurs. */
  121. #define ref_mark_old(pto) ((pto)->tas.type_attrs &= ~ialloc_new_mask)
  122.  
  123. /* Define macros for conditionally clearing the parts of a ref */
  124. /* that aren't being set to anything useful. */
  125.  
  126. #ifdef DEBUG
  127. #  define and_fill_s(pref)\
  128.     , (gs_debug['$'] ? r_set_size(pref, 0xfeed) : 0)
  129. #  define and_fill_sv(pref)\
  130.     , (gs_debug['$'] ? (r_set_size(pref, 0xfeed),\
  131.             (pref)->value.intval = 0xdeadbeef) : 0)
  132. #else                /* !DEBUG */
  133. #  define and_fill_s(pref) /* */
  134. #  define and_fill_sv(pref) /* */
  135. #endif
  136.  
  137. /* make_t must set the attributes to 0 to clear a_local! */
  138. #define make_t(pref,newtype)\
  139.   (r_set_type_attrs(pref, newtype, 0) and_fill_sv(pref))
  140. #define make_t_new(pref,newtype)\
  141.   (r_set_type_attrs(pref, newtype, ialloc_new_mask) and_fill_sv(pref))
  142. #define make_t_old(pcont,pref,newtype,cname)\
  143.   (ref_save(pcont,pref,cname), make_t_new(pref,newtype))
  144.  
  145. #define make_tav(pref,newtype,newattrs,valfield,newvalue)\
  146.   ((pref)->value.valfield = (newvalue),\
  147.    r_set_type_attrs(pref, newtype, newattrs)\
  148.    and_fill_s(pref))
  149. #define make_tav_new(pref,t,a,vf,v)\
  150.   make_tav(pref,t,(a)|ialloc_new_mask,vf,v)
  151. #define make_tav_old(pcont,pref,t,a,vf,v,cname)\
  152.   (ref_save(pcont,pref,cname), make_tav_new(pref,t,a,vf,v))
  153.  
  154. #define make_tv(pref,newtype,valfield,newvalue)\
  155.   make_tav(pref,newtype,0,valfield,newvalue)
  156. #define make_tv_new(pref,t,vf,v)\
  157.   make_tav_new(pref,t,0,vf,v)
  158. #define make_tv_old(pcont,pref,t,vf,v,cname)\
  159.   make_tav_old(pcont,pref,t,0,vf,v,cname)
  160.  
  161. #define make_tasv(pref,newtype,newattrs,newsize,valfield,newvalue)\
  162.   ((pref)->value.valfield = (newvalue),\
  163.    r_set_type_attrs(pref, newtype, newattrs),\
  164.    r_set_size(pref, newsize))
  165. #define make_tasv_new(pref,t,a,s,vf,v)\
  166.   make_tasv(pref,t,(a)|ialloc_new_mask,s,vf,v)
  167. #define make_tasv_old(pcont,pref,t,a,s,vf,v,cname)\
  168.   (ref_save(pcont,pref,cname), make_tasv_new(pref,t,a,s,vf,v))
  169.  
  170. /* Type-specific constructor macros for scalar (non-composite) types */
  171.  
  172. #define make_bool(pref,bval)\
  173.   make_tv(pref, t_boolean, boolval, bval)
  174. #define make_false(pref)\
  175.   make_bool(pref, 0)
  176. #define make_true(pref)\
  177.   make_bool(pref, 1)
  178.  
  179. #define make_int(pref,ival)\
  180.   make_tv(pref, t_integer, intval, ival)
  181. #define make_int_new(pref,ival)\
  182.   make_tv_new(pref, t_integer, intval, ival)
  183.  
  184. #define make_mark(pref)\
  185.   make_t(pref, t_mark)
  186.  
  187. #define make_null(pref)\
  188.   make_t(pref, t_null)
  189. #define make_null_new(pref)\
  190.   make_t_new(pref, t_null)
  191. #define make_null_old(pcont,pref,cname)\
  192.   make_t_old(pcont, pref, t_null, cname)
  193.  
  194. #define make_oper(pref,opidx,proc)\
  195.   make_tasv(pref, t_operator, a_executable, opidx, opproc, proc)
  196.  
  197. #define make_real(pref,rval)\
  198.   make_tv(pref, t_real, realval, rval)
  199. #define make_real_new(pref,rval)\
  200.   make_tv_new(pref, t_real, realval, rval)
  201.  
  202. /* Type-specific constructor macros for composite types */
  203.  
  204. /* For composite types, the a_space field is relevant; however, */
  205. /* as noted in ivmspace.h, a value of 0 designates the most static space, */
  206. /* so for making empty composites, a space value of 0 is appropriate. */
  207.  
  208. #define make_array(pref,attrs,size,elts)\
  209.   make_tasv(pref, t_array, attrs, size, refs, elts)
  210. #define make_array_new(pref,attrs,size,elts)\
  211.   make_tasv_new(pref, t_array, attrs, size, refs, elts)
  212. #define make_const_array(pref,attrs,size,elts)\
  213.   make_tasv(pref, t_array, attrs, size, const_refs, elts)
  214. #define make_empty_array(pref,attrs)\
  215.   make_array(pref, attrs, 0, (ref *)NULL)
  216. #define make_empty_const_array(pref,attrs)\
  217.   make_const_array(pref, attrs, 0, (const ref *)NULL)
  218.  
  219. #define make_string(pref,attrs,size,chars)\
  220.   make_tasv(pref, t_string, attrs, size, bytes, chars)
  221. #define make_const_string(pref,attrs,size,chars)\
  222.   make_tasv(pref, t_string, attrs, size, const_bytes, chars)
  223. #define make_empty_string(pref,attrs)\
  224.   make_string(pref, attrs, 0, (byte *)NULL)
  225. #define make_empty_const_string(pref,attrs)\
  226.   make_const_string(pref, attrs, 0, (const byte *)NULL)
  227.  
  228. #define make_struct(pref,attrs,ptr)\
  229.   make_tav(pref, t_struct, attrs, pstruct, (obj_header_t *)(ptr))
  230. #define make_struct_new(pref,attrs,ptr)\
  231.   make_tav_new(pref, t_struct, attrs, pstruct, (obj_header_t *)(ptr))
  232.  
  233. #define make_astruct(pref,attrs,ptr)\
  234.   make_tav(pref, t_astruct, attrs, pstruct, (obj_header_t *)(ptr))
  235. #define make_astruct_new(pref,attrs,ptr)\
  236.   make_tav_new(pref, t_astruct, attrs, pstruct, (obj_header_t *)(ptr))
  237.